Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add forbidden regex #377

Merged
merged 18 commits into from
Dec 16, 2024
Merged

Conversation

bormilan
Copy link
Contributor

@bormilan bormilan commented Dec 1, 2024

Description

I added the `forbidden_regex' to all "naming_convention" rules.
I made tests for a simple case about making numbers forbidden.

I can't decide in these situations that making a "case in case" is a good implementation. I feel that moving these into another function is not much cleaner, and maybe reading is more frustrating if you need to look into another function just for another case. What do you think about it?

Closes #151.

src/elvis_style.erl Outdated Show resolved Hide resolved
doc_rules/elvis_style/atom_naming_convention.md Outdated Show resolved Hide resolved
doc_rules/elvis_style/atom_naming_convention.md Outdated Show resolved Hide resolved
src/elvis_style.erl Outdated Show resolved Hide resolved
@bormilan bormilan force-pushed the change-naming-conventions branch from dddb8af to 40edae8 Compare December 5, 2024 15:33
doc_rules/elvis_style/atom_naming_convention.md Outdated Show resolved Hide resolved
src/elvis_style.erl Outdated Show resolved Hide resolved
src/elvis_style.erl Outdated Show resolved Hide resolved
src/elvis_style.erl Outdated Show resolved Hide resolved
src/elvis_style.erl Outdated Show resolved Hide resolved
@bormilan
Copy link
Contributor Author

bormilan commented Dec 5, 2024

But what's the problem with andalso? or why do we want to avoid it?

@elbrujohalcon
Copy link
Member

elbrujohalcon commented Dec 5, 2024

But what's the problem with andalso? or why do we want to avoid it?

The implicit specification for andalso (giving its desired semantics) is boolean() andalso boolean() -> boolean(), but the actual way in which andalso works is (as you noticed in your code) boolean() andalso Type -> Type. In other words, while it's semantically expected for the second expression to be boolean… it works anyway if it's not because that's how the VM optimizes this code.

Taking advantage of an optimization to mess up with the expected semantics of an expression is not a great thing to do. First of all, nothing prevents the OTP team from changing that behaviour in the future and crash if the second part is not a boolean (that would be semantically correct, anyway). But more importantly… for developers reading that code… finding something that's not a boolean there is unexpected and surprising future devs is not usually a good thing in terms of maintainability.

@elbrujohalcon
Copy link
Member

I'll leave the PR open for another day so @paulo-ferraz-oliveira can review… and if he doesn't request changes by then, I'll merge it.

Copy link
Collaborator

@paulo-ferraz-oliveira paulo-ferraz-oliveira left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Generally approving, but did comment on a few things that could be improved.

@bormilan
Copy link
Contributor Author

bormilan commented Dec 6, 2024

But what's the problem with andalso? or why do we want to avoid it?

The implicit specification for andalso (giving its desired semantics) is boolean() andalso boolean() -> boolean(), but the actual way in which andalso works is (as you noticed in your code) boolean() andalso Type -> Type. In other words, while it's semantically expected for the second expression to be boolean… it works anyway if it's not because that's how the VM optimizes this code.

Taking advantage of an optimization to mess up with the expected semantics of an expression is not a great thing to do. First of all, nothing prevents the OTP team from changing that behaviour in the future and crash if the second part is not a boolean (that would be semantically correct, anyway). But more importantly… for developers reading that code… finding something that's not a boolean there is unexpected and surprising future devs is not usually a good thing in terms of maintainability.

Thank you for this explanation. I truly appreciate these "small"(but important) things that I can't learn anywhere else. Thanks again for the effort you put into these reviews!

@paulo-ferraz-oliveira
Copy link
Collaborator

@bormilan, it's also one of the reasons behind https://github.com/inaka/elvis_core/blob/main/doc_rules/elvis_style/no_block_expressions.md. I was seeing (and writing, since Erlang didn't forbid me) code like:

Connected andalso begin
  NumberOfEvents = num_events(...)
  NumberOfEvents > 10 orelse log(...)
end

While that works, it's generally messy to maintain.

@bormilan
Copy link
Contributor Author

bormilan commented Dec 9, 2024

@bormilan, it's also one of the reasons behind https://github.com/inaka/elvis_core/blob/main/doc_rules/elvis_style/no_block_expressions.md. I was seeing (and writing, since Erlang didn't forbid me) code like:

Connected andalso begin
  NumberOfEvents = num_events(...)
  NumberOfEvents > 10 orelse log(...)
end

While that works, it's generally messy to maintain.

Thank you for the hint and all the reviews, too!

@bormilan
Copy link
Contributor Author

If it's okay, I will rebase it to prepare for the merge.

@elbrujohalcon
Copy link
Member

We can just squash and merge, no need for rebasing.

@elbrujohalcon elbrujohalcon merged commit ecc035a into inaka:main Dec 16, 2024
7 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Extend naming conventions with things to avoid
3 participants